home *** CD-ROM | disk | FTP | other *** search
/ Mac Format 2004 Junue - Disc 1 / MacFormat 143 CD1.iso / Serious Software / RealCADD3.05.sit / RealCADD3.05 / scripts / nuage < prev    next >
Text File  |  2003-04-07  |  2KB  |  97 lines

  1. RCAD script
  2. 1.00
  3. nuage
  4. nuageup
  5. nuagedown
  6. 0
  7. 0
  8. 0
  9.  
  10.  
  11.  
  12.  
  13.  
  14.  
  15.  
  16.  
  17.  
  18.  
  19.  
  20.  
  21.  
  22.  
  23.  
  24.  
  25.  
  26.  
  27.  
  28.  
  29. Dim s_nb, s_i, s_k as integer
  30. Dim s_x1, s_y1, s_x2, s_y2, s_xc, s_yc, s_r, s_angle, s_angle1, s_angle2, s_xcc as double
  31.  
  32. sub angle2points(fx1 as double, fy1 as double, fx2 as double, fy2 as double)
  33. Dim s_dx, s_dy as double
  34.    //Calcul angle
  35.    s_dx = fx1 - fx2
  36.    s_dy = fy1 - fy2
  37.   
  38.    if s_dx <> 0 then
  39.       s_angle = abs(Atan(s_dy / s_dx))
  40.       if s_dx > 0 then
  41.          if s_dy < 0 then
  42.             s_angle = 6.283185307179586 - s_angle
  43.          end if
  44.       else
  45.          if s_dy > 0 then
  46.             s_angle = 3.141592653589793 - s_angle
  47.          else
  48.             s_angle = 3.141592653589793 + s_angle
  49.          end if
  50.       end if
  51.    else
  52.       if s_dy = 0 then
  53.          s_angle = 0
  54.       else
  55.          if s_dy > 0 then
  56.             s_angle = 1.570796326794897
  57.          else
  58.             s_angle = 4.71238898038469
  59.          end if
  60.       end if
  61.    end if
  62.    s_angle = s_angle * 180 / 3.141592653589793
  63. end sub
  64.  
  65. s_xcc = (firstx + lastx) / 2
  66. Add_Oval(firstx, firsty, lastx, lasty, 1, 7, 0,false)
  67. DoConvertObjectToPolygon(Dim_Liste)
  68. s_nb = Dim_Liste
  69.  
  70. s_x2 = XValueObjet_Point(s_nb,0)
  71. s_y2 = YValueObjet_Point(s_nb,0)
  72. s_i = 0
  73. Do
  74.    s_i = s_i + 6 + round(6 * Rnd)
  75.    if s_i > 140 then
  76.       s_i = 144
  77.    end if
  78.    s_x1 = s_x2
  79.    s_y1 = s_y2
  80.    s_x2 = XValueObjet_Point(s_nb,s_i)
  81.    s_y2 = YValueObjet_Point(s_nb,s_i)
  82.    s_xc = (s_x1 + s_x2) / 2
  83.    s_yc = (s_y1 + s_y2) / 2
  84.    s_r = sqrt(Pow(s_x1- s_xc,2) + Pow(s_y1 - s_yc,2))
  85.    angle2points(s_xc, s_yc, s_x1, s_y1)
  86.    s_angle1 = s_angle
  87.    angle2points(s_xc, s_yc, s_x2, s_y2)
  88.    s_angle2 = s_angle
  89.    if s_xcc > s_xc then
  90.       Add_Arc(s_xc, s_yc, s_r, s_angle1, s_angle2 - s_angle1, 3, 7, 0, False, False)
  91.    else
  92.       Add_Arc(s_xc, s_yc, s_r, s_angle1, s_angle1 - s_angle2, 3, 7, 0, False, False)
  93.    end if
  94. Loop until s_i >= 144
  95.  
  96. Delete_Objet(s_nb)
  97.